12

## IN THE CLAIMS

This listing of claims will replace all prior versions, and listings, of claims in the application:

- 1. (Currently Amended) A computer system having a plurality of resources, comprising: 1 2 a first processor coupled to a first bus; a second processor coupled to a second bus; and 3 an instruction memory coupled to the first and second processors bus and the second bus 4 and having a software direct memory access (DMA) engine stored therein, wherein 5 the software DMA engine engine, when is adapted to be executed by a processor 6 7 of the first and second processors, being the processor being coupled to the 8 first bus and the second bus, and wherein the software DMA engine is capable of transferring data directly between all 9 10 resources in the computer system. of the plurality of resources, each of the plurality of resources being connected to at least one of the first bus and the 11
- (Previously Presented) The system of Claim 1, wherein transferring data includes one or
   more of data processing, data filtering, data compacting and data reformatting.
- 1 3. (Original) The system of Claim 2, wherein the resources comprise one or more of static
- 2 random access memory, dynamic random access memory and one or more hardware buffers that
- 3 are capable of interfacing with one or more peripheral devices.

second bus.

- 4. (Previously Presented) The system of Claim 3, wherein the one or more hardware
- 2 buffers, in combination with the software DMA engine, permit the one or more peripherals to
- 3 access the memory directly.
- 1 5. (Previously Presented) The system of Claim 3, wherein the software DMA engine
- 2 comprises one or more instructions, the one or more instructions including a store multiple data
- 3 instruction and a load multiple data instruction wherein, when executed by the processor:
- 4 the load multiple data instruction loads data from multiple locations in one of the

60391477v1

6

1

2

3

4 5

6 7

8

9

10

11

12 13 the store multiple data instruction transfers the data from multiple locations in the internal

7 registers into multiple locations in a memory.

- 6. (Currently Amended) A direct memory access (DMA) apparatus implemented in software on a computer system, the computer system having two or more processors and a memory coupled to each of the two or more processors, the DMA apparatus comprising:
  a first instruction memory location in the computer system with a load multiple data instruction loaded therein; and
  a second instruction memory location in the computer system with a store multiple data instruction loaded therein, wherein
  the load multiple data instruction, when executed by a processor in the computer system, is capable of loading data from multiple locations in a resource into multiple locations in an internal register in the processor; and
  the store multiple data instruction, when executed by the processor in the computer system, is capable of storing data from multiple locations in the internal register in the processor into multiple locations in a memory.
- 7. (Original) The apparatus of Claim 6, wherein the resources comprise one or more of static random access memory, dynamic random access memory and one or more hardware buffers that are capable of interfacing with one or more peripheral devices.
- 1 8. (Previously Presented) The apparatus of Claim 7, wherein the one or more hardware
  2 buffers, in combination with the DMA apparatus, permit the one or more peripherals to access
  3 the memory directly.
- (Previously Presented) The apparatus of Claim 6, wherein the store multiple data
   instruction and the load multiple data instruction, when executed by the processor, each further
   include one or more of data processing, data filtering, data compacting and data reformatting.
  - 10. (Canceled).